package com.maxqiu.demo;

import org.apache.shiro.authc.AuthenticationException;
import org.apache.shiro.authc.AuthenticationInfo;
import org.apache.shiro.authc.AuthenticationToken;
import org.apache.shiro.authc.SimpleAuthenticationInfo;
import org.apache.shiro.realm.AuthenticatingRealm;
import org.apache.shiro.util.ByteSource;

/**
 * @author Max_Qiu
 */
public class MyRealm extends AuthenticatingRealm {
    // 自定义登录认证方法，shiro的login方法底层会调用该类的认证方法进行认证
    // 需要配置自定义的realm生效，在ini文件中配置，在Springboot中配置
    // 该方法只是获取进行对比的信息，认证逻辑还是按照shiro底层认证逻辑完成
    @Override
    protected AuthenticationInfo doGetAuthenticationInfo(AuthenticationToken authenticationToken) throws AuthenticationException {
        // 1获取身份信息
        String principal = authenticationToken.getPrincipal().toString();
        // 2获取凭证信息
        String password = new String((char[])authenticationToken.getCredentials());
        System.out.println("认证用户信息：" + principal + "---" + password);
        // 3获取数据库中存储的用户信息
        if ("zhangsan".equals(principal)) {
            // 3.1数据库中存储的加盐3次迭代的密码
            String pwdInfo = "7174f64b13022acd3c56e2781e098a5f";
            // 4创建封装校验逻辑对象，封装数据返回
            return new SimpleAuthenticationInfo(authenticationToken.getPrincipal(), pwdInfo, ByteSource.Util.bytes("salt"),
                authenticationToken.getPrincipal().toString());
        }
        return null;
    }
}
